<template>
  <el-dialog :title="form.id ? $t('common.editBtn') : $t('common.addBtn')" v-model="visible">
    <el-form ref="dataFormRef" :model="form" :rules="dataRules" formDialogRef label-width="90px" v-loading="loading">
      <el-row :gutter="24">
        <el-col :span="24" class="mb20">
          <el-form-item :label="t('schedule.title')" prop="title">
            <el-input v-model="form.title" :placeholder="t('schedule.inputTitleTip')"/>
          </el-form-item>
        </el-col>

        <el-col :span="24" class="mb20">
          <el-form-item :label="t('schedule.type')" prop="type">
            <el-select v-model="form.type" :placeholder="t('schedule.inputTypeTip')" clearable default-first-option>
              <el-option v-for="item in schedule_type" :key="item.value" :label="item.label" :value="item.value"/>
            </el-select>
          </el-form-item>
        </el-col>

        <el-col :span="24" class="mb20">
          <el-form-item :label="t('schedule.state')" prop="state">
            <el-select v-model="form.state" :placeholder="t('schedule.inputStateTip')" clearable default-first-option>
              <el-option v-for="item in schedule_status" :key="item.value" :label="item.label" :value="item.value"/>
            </el-select>
          </el-form-item>
        </el-col>
        <el-col :span="12" class="mb20">
          <el-form-item :label="t('schedule.date')" prop="date">
            <el-date-picker type="date" :placeholder="t('schedule.inputDateTip')" v-model="form.date"
                            :value-format="dateStr"/>
          </el-form-item>
        </el-col>
        <el-col :span="12" class="mb20">
          <el-form-item :label="t('schedule.time')" prop="time">
            <el-time-picker v-model="form.time" arrow-control :placeholder="t('schedule.inputTimeTip')"
                            :value-format="timeStr"/>
          </el-form-item>
        </el-col>

        <el-col :span="24" class="mb20">
          <el-form-item :label="t('schedule.content')" prop="content">
            <editor v-model:get-html="form.content" :placeholder="t('schedule.inputContentTip')"
                    :disable="form.id !== ''" v-if="visible"/>
          </el-form-item>
        </el-col>
      </el-row>
    </el-form>
    <template #footer>
			<span class="dialog-footer">
				<el-button @click="visible = false">{{ $t('common.cancelButtonText') }}</el-button>
				<el-button type="primary" @click="onSubmit" :disabled="loading">{{ $t('common.confirmButtonText') }}</el-button>
			</span>
    </template>
  </el-dialog>
</template>

<script setup lang="ts" name="SysScheduleDialog">
import {useMessage} from '/@/hooks/message';
import {addObj, getObj, putObj} from '/@/api/admin/schedule';
import {useI18n} from 'vue-i18n';
import {useDict} from '/@/hooks/dict';

const emit = defineEmits(['refresh']);

// 获取字典内容
const {schedule_type, schedule_status} = useDict('schedule_type', 'schedule_status');

// 使用国际化实例
const {t} = useI18n();

// 定义变量内容
const dataFormRef = ref();
const visible = ref(false);
const loading = ref(false);

// 提交表单数据
const form = reactive({
  id: '',
  title: '',
  type: 'record',
  state: '0',
  content: '',
  time: '',
  date: '',
});

// 定义校验规则
const dataRules = ref({
  title: [{required: true, message: '标题不能为空', trigger: 'blur'}],
  type: [{required: true, message: '日程类型不能为空', trigger: 'blur'}],
  state: [{required: true, message: '状态不能为空', trigger: 'blur'}],
  content: [{required: true, message: '内容不能为空', trigger: 'blur'}],
  time: [{required: true, message: '时间不能为空', trigger: 'blur'}],
  date: [{required: true, message: '日期不能为空', trigger: 'blur'}],
});

/**
 * 打开日程表单弹窗
 * @function
 * @param {string} id - 日程ID
 * @param {Object} row - 行数据
 */
const openDialog = (id: string, row: any) => {
  visible.value = true;
  form.id = '';

  // 重置表单数据
  nextTick(() => dataFormRef.value?.resetFields());

  if (row?.date) {
    form.date = row.date;
  }

  // 获取sysSchedule信息
  if (id) {
    form.id = id;
    getsysScheduleData(id);
  }
};

/**
 * 提交表单数据
 * @function
 * @async
 */
const onSubmit = async () => {
  // 验证表单是否符合规则
  const valid = await dataFormRef.value.validate().catch(() => {
  });
  if (!valid) return false;

  try {
    loading.value = true;
    await (form.id ? putObj(form) : addObj(form));
    useMessage().success(t(form.id ? 'common.editSuccessText' : 'common.addSuccessText'));
    visible.value = false;
    emit('refresh');
  } catch (err: any) {
    useMessage().error(err.msg);
  } finally {
    loading.value = false;
  }
};

/**
 * 获取sysSchedule数据
 * @function
 * @param {string} id - 日程ID
 */
const getsysScheduleData = (id: string) => {
  // 获取数据
  loading.value = true;
  getObj(id)
      .then((res: any) => Object.assign(form, res.data))
      .finally(() => (loading.value = false));
};

// 暴露变量
defineExpose({openDialog});
</script>
